home *** CD-ROM | disk | FTP | other *** search
/ Revista do CD-ROM 101 / CD-ROM 101.iso / compl / maya5ple / Install_MayaPLE5_English.exe / Maya / Data1.cab / visorAddNewDiskFolder.mel < prev    next >
Encoding:
Text File  |  2003-07-17  |  4.3 KB  |  134 lines

  1. // Copyright (C) 1997-2002 Alias|Wavefront,
  2. // a division of Silicon Graphics Limited.
  3. //
  4. // The information in this file is provided for the exclusive use of the
  5. // licensees of Alias|Wavefront.  Such users have the right to use, modify,
  6. // and incorporate this code into other products for purposes authorized
  7. // by the Alias|Wavefront license agreement, without fee.
  8. //
  9. // ALIAS|WAVEFRONT DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  10. // INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
  11. // EVENT SHALL ALIAS|WAVEFRONT BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  12. // CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  13. // DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  14. // TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  15. // PERFORMANCE OF THIS SOFTWARE.
  16. //
  17. // Copyright (C) 1999 Alias|Wavefront,
  18. // a division of Silicon Graphics Limited.
  19. //
  20. // The information in this file is provided for the exclusive use of the
  21. // licensees of Alias|Wavefront.  Such users have the right to use, modify,
  22. // and incorporate this code into other products for purposes authorized
  23. // by the Alias|Wavefront license agreement, without fee.
  24. //
  25. // ALIAS|WAVEFRONT DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  26. // INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
  27. // EVENT SHALL ALIAS|WAVEFRONT BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  28. // CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  29. // DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  30. // TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  31. // PERFORMANCE OF THIS SOFTWARE.
  32. //
  33. //
  34. //  Alias|Wavefront Script File
  35. //  MODIFY THIS AT YOUR OWN RISK
  36. //
  37. //  Creation Date:  Date
  38. //  Author:         jdc rendering
  39. //
  40. // Description:
  41. //
  42. //        description
  43. //                                                
  44.  
  45. global proc int visorAddNewDiskFolderCallback(
  46.     string $visor,
  47.     string $path,
  48.     string $type)
  49. //
  50. // Description:
  51. //    This procedure is called by the file browser which was opened to allow the
  52. //    user to choose which directory to open the disk folder in.
  53. //    This procedure creates the folder and adds the directory to the list of
  54. //    directories for which disk folders should exist. The list is stored as an
  55. //    optionVar so that it will persist between sessions and across projects.
  56. //
  57. // Returns: 
  58. //    The return value is a boolean indicating whether the user's choice from
  59. //    the file browser was valid. If it was invalid, the user will have the
  60. //    opportunity to choose another.
  61. //
  62. {
  63.     int $result;
  64.  
  65.     string $typeList[] = `file -q -typ $path`;
  66.     if (size($typeList) > 0 && $typeList[0] == "directory") 
  67.     {
  68.         // On NT when the file browser returns a directory path, it doesn't
  69.         // have a "/" at the end. On IRIX it does. The visor ensures the path
  70.         // ends in "/" regardless of OS. So in order for users to be able to
  71.         // remove the folders they create on NT, it's just easier to ensure
  72.         // the path ends in "/".
  73.         //
  74.  
  75.         if(!`about -mac`){
  76.             if (substring($path, size($path), size($path)) != "/")
  77.             {
  78.                 $path = ($path + "/");
  79.             }
  80.         }
  81.         visor
  82.             -addFolder 
  83.             -type directory
  84.             -openFolder true
  85.             -path $path 
  86.             -name $path
  87.             $visor;
  88.         visor -rebuild $visor;
  89.  
  90.         // Add the folder to the optionVar which remembers the user's custom
  91.         // disk folders
  92.         //
  93.         optionVar -stringValueAppend visorCustomDiskFolders $path;
  94.  
  95.         $result = true;
  96.     } 
  97.     else 
  98.     {
  99.         confirmDialog -m ($path+" is not a directory.") 
  100.             -b "OK" -db "OK" -parent projectViewerWindow;
  101.         $result = false;
  102.     }
  103.  
  104.     return $result;
  105. }
  106.  
  107. global proc visorAddNewDiskFolder(
  108.     string $visor)
  109. //
  110. // Description:
  111. //    This procedure is called when the user chooses "Add new disk folder" from
  112. //    the RMB menu in Visor. 
  113. //    This procedure opens a file browser to allow the user to choose which
  114. //    directory the folder should correspond to.
  115. //    The file browser will call the callback procedure above to actually create
  116. //    the folder.
  117. //
  118. {
  119.     // Set the directory to the users project area.
  120.     //
  121.     string $wsDir = dirname( `workspace -q -fn` );
  122.  
  123.     if (`file -q -ex $wsDir`) 
  124.     {
  125.         workspace -dir $wsDir;
  126.     }
  127.  
  128.     fileBrowser( 
  129.         ("visorAddNewDiskFolderCallback " + $visor), 
  130.         "Choose Folder", 
  131.         "", 
  132.         4);
  133. }
  134.